<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>用户管理</title>
    <meta name="renderer" content="webkit" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
    <link rel="stylesheet" href="../../lib/layui/css/layui.css" media="all" />
    <link rel="stylesheet" href="../../css/public.css" media="all" />
  </head>

  <body>
    <div class="layuimini-container">
      <div class="layuimini-main">
        <fieldset class="table-search-fieldset">
          <legend>搜索信息</legend>
          <div style="margin: 10px 10px 10px 10px">
            <form class="layui-form layui-form-pane" action="">
              <div class="layui-form-item">
                <div class="layui-inline">
                  <label class="layui-form-label">ID</label>
                  <div class="layui-input-inline">
                    <input type="text" name="id" autocomplete="off" class="layui-input" />
                  </div>
                </div>
                <div class="layui-inline">
                  <label class="layui-form-label">用户名</label>
                  <div class="layui-input-inline">
                    <input type="text" name="username" autocomplete="off" class="layui-input" />
                  </div>
                </div>
                <div class="layui-inline">
                  <label class="layui-form-label">昵称</label>
                  <div class="layui-input-inline">
                    <input type="text" name="name" autocomplete="off" class="layui-input" />
                  </div>
                </div>
                <div class="layui-inline">
                  <button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="data-search-btn">
                    <i class="layui-icon"></i> 搜 索
                  </button>
                </div>
              </div>
            </form>
          </div>
        </fieldset>

        <table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter"></table>
      </div>
    </div>
    <script src="../../lib/layui/layui.js" charset="utf-8"></script>
    <script src="../../js/lay-config.js" charset="utf-8"></script>
    <script type="text/html" id="toolbarDemo">
      <div class="layui-btn-container">
        <button class="layui-btn layui-btn-normal layui-btn-sm data-add-btn" lay-event="add">添加</button>
      </div>
    </script>
    <script type="text/html" id="state">
      <input type="checkbox" name="state" value="{{d.id}}" lay-skin="switch" lay-text="启用|禁用" lay-filter="state" {{
      d.state == 1 ? 'checked' : '' }}>
    </script>
    <!-- 操作列 -->
    <script type="text/html" id="currentTableBar">
      <a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="edit">修改</a>
      <a class="layui-btn layui-btn-xs {{d.id == 1 ? 'layui-hide' : ''}}" lay-event="role">角色</a>
      <a class="layui-btn layui-btn-danger layui-btn-xs {{d.id == 1 ? 'layui-hide' : ''}}" lay-event="del">删除</a>
    </script>
    <script>
      layui.use(['form', 'table'], function () {
        var $ = layui.jquery,
          form = layui.form,
          table = layui.table;

        table.render({
          elem: '#currentTableId',
          url: '/admin/user/list', // 换成相应的运营平台接口
          toolbar: '#toolbarDemo',
          defaultToolbar: ['filter', 'exports', 'print'],
          parseData: function (res) {
            //res 即为原始返回的数据
            return {
              code: res.code == 200 ? 0 : res.code, //解析接口状态
              msg: res.message, //解析提示文本
              count: res.data.total, //解析数据长度
              data: res.data.data, //解析数据列表
            };
          },
          cols: [
            [
              {
                field: 'id',
                width: 80,
                title: 'ID',
              },
              {
                field: 'username',
                title: '用户名',
              },
              {
                field: 'name',
                title: '昵称',
              },
              {
                field: 'avatar',
                title: '头像',
                templet: function (d) {
                  if (d.avatar) {
                    return `<img src="${d.avatar}" alt="${d.name}" width="30" height="30" />`;
                  }
                  return '';
                },
              },
              {
                field: 'state',
                width: 100,
                title: '状态',
                align: 'center',
                templet: '#state',
              },
              {
                field: 'created_at',
                title: '创建时间',
              },
              { templet: '#currentTableBar', width: 180, align: 'center', title: '操作' },
            ],
          ],
          limits: [10, 15, 20, 25, 50, 100],
          limit: 15,
          page: true,
        });

        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {
          var result = JSON.stringify(data.field);

          //执行搜索重载
          table.reload(
            'currentTableId',
            {
              page: {
                curr: 1,
              },
              where: {
                searchParams: result,
              },
            },
            'data'
          );

          return false;
        });

        form.on('switch(state)', function (obj) {
          $.ajax({
            url: '/admin/user/changeState',
            type: 'POST',
            data: {
              id: this.value,
              state: obj.elem.checked,
            },
            success: function (res) {
              layer.msg(res.message);
            },
          });
        });

        /**
         * toolbar监听事件
         */
        table.on('toolbar(currentTableFilter)', function (obj) {
          if (obj.event === 'add') {
            // 监听添加操作
            var index = layer.open({
              title: '添加用户',
              type: 2,
              shade: 0.2,
              maxmin: true,
              shadeClose: true,
              area: ['100%', '100%'],
              content: 'add.html',
            });
            $(window).on('resize', function () {
              layer.full(index);
            });
          }
        });

        //监听表格复选框选择
        table.on('checkbox(currentTableFilter)', function (obj) {
          // console.log(obj)
        });

        //监听工具条
        table.on('tool(currentTableFilter)', function (obj) {
          var data = obj.data;
          var layEvent = obj.event;

          if (layEvent === 'del') {
            layer.confirm(
              `是否确认要删除用户：<span style="color: blue; font-weight:bold;">${data.name}</span>？`,
              function (index) {
                $.ajax({
                  url: '/admin/user/delete',
                  type: 'post',
                  data: { id: data.id },
                  success: function (data) {
                    if (data.code != 200) {
                      layer.msg(data.message);
                      return;
                    }

                    layer.msg(data.message || '删除成功');
                    obj.del();
                    layer.close(index);
                  },
                });
              }
            );
          } else if (layEvent === 'edit') {
            sessionStorage.setItem('edit_id', data.id);

            var index = layer.open({
              title: '修改用户',
              type: 2,
              shade: 0.2,
              maxmin: true,
              shadeClose: true,
              area: ['100%', '100%'],
              content: 'edit.html',
            });
            $(window).on('resize', function () {
              layer.full(index);
            });
          } else if (layEvent === 'role') {
            sessionStorage.setItem('id', data.id);

            var index = layer.open({
              title: '设置角色',
              type: 2,
              shade: 0.2,
              maxmin: true,
              shadeClose: true,
              area: ['100%', '100%'],
              content: 'role.html?id=' + data.id,
            });
            $(window).on('resize', function () {
              layer.full(index);
            });
          }
        });
      });
    </script>
    <script></script>
  </body>
</html>
